<?php

namespace app\home\model\user;

use traits\ModelTrait;
use basic\BaseModel;
use think\facade\Db;

/**
 * 用户消费新增金额明细 model
 * Class UserBill
 * @package app\home\model\user
 */
class UserBill extends BaseModel
{
    /**
     * 数据表主键
     * @var string
     */
    protected $pk = 'id';

    /**
     * 模型名称
     * @var string
     */
    protected $name = 'user_bill';

    use ModelTrait;

    /*
     * 获取总佣金
     * */
    public static function getBrokerage($uid, $category = 'now_money', $type = 'brokerage', $where)
    {
        return self::getModelTime($where, self::where('uid', 'in', $uid)->where('category', $category)
            ->where('type', $type)->where('pm', 1)->where('status', 1))->sum('number');
    }

    //修改积分减少积分记录
    public static function expend($title, $uid, $category, $type, $number, $link_id = 0, $balance = 0, $mark = '', $status = 1)
    {
        $pm = 0;
        $add_time = time();
        return self::create(compact('title', 'uid', 'link_id', 'category', 'type', 'number', 'balance', 'mark', 'status', 'pm', 'add_time'));
    }

    //修改积分增加积分记录
    public static function income($title, $uid, $category, $type, $number, $link_id = 0, $balance = 0, $mark = '', $status = 1)
    {
        $pm = 1;
        $add_time = time();
        return self::create(compact('title', 'uid', 'link_id', 'category', 'type', 'number', 'balance', 'mark', 'status', 'pm', 'add_time'));
    }

    //获取柱状图和饼状图数据
    public static function getUserBillChart($where, $category = 'now_money', $type = 'brokerage', $pm = 1, $zoom = 15)
    {
        $model = self::getModelTime($where, new self());
        $list = $model->field('FROM_UNIXTIME(add_time,"%Y-%c-%d") as un_time,sum(number) as sum_number')
            ->order('un_time asc')
            ->where('category', $category)
            ->where('type', $type)
            ->where('pm', $pm)
            ->group('un_time')
            ->select();
        if (count($list)) $list = $list->toArray();
        $legdata = [];
        $listdata = [];
        $dataZoom = '';
        foreach ($list as $item) {
            $legdata[] = $item['un_time'];
            $listdata[] = $item['sum_number'];
        }
        if (count($legdata) >= $zoom) $dataZoom = $legdata[$zoom - 1];
        //获取用户分布钱数
        $fenbulist = self::getModelTime($where, new self(), 'a.add_time')
            ->alias('a')
            ->join('user r', 'a.uid=r.uid')
            ->field('a.uid,sum(a.number) as sum_number,r.nickname')
            ->where('a.category', $category)
            ->where('a.type', $type)
            ->where('a.pm', $pm)
            ->order('sum_number desc')
            ->group('a.uid')
            ->limit(8)
            ->select();
        //获取用户当前时间段总钱数
        $sum_number = self::getModelTime($where, new self())
            ->alias('a')
            ->where('a.category', $category)
            ->where('a.type', $type)
            ->where('a.pm', $pm)
            ->sum('number');
        if (count($fenbulist)) $fenbulist = $fenbulist->toArray();
        $fenbudate = [];
        $fenbu_legend = [];
        $color = ['#ffcccc', '#99cc00', '#fd99cc', '#669966', '#66CDAA', '#ADFF2F', '#00BFFF', '#00CED1', '#66cccc', '#ff9900', '#ffcc00', '#336699', '#cccc00', '#99ccff', '#990066'];
        foreach ($fenbulist as $key => $value) {
            $fenbu_legend[] = $value['nickname'];
            $items['name'] = $value['nickname'];
            $items['value'] = bcdiv($value['sum_number'], $sum_number, 2) * 100;
            $items['itemStyle']['color'] = $color[$key];
            $fenbudate[] = $items;
        }
        return compact('legdata', 'listdata', 'fenbudate', 'fenbu_legend', 'dataZoom');
    }

    //获取头部信息
    public static function getRebateBadge($where)
    {
        $datawhere = ['category' => 'now_money', 'type' => 'brokerage', 'pm' => 1];
        return [
            [
                'name' => '返利数(笔)',
                'field' => '个',
                'count' => self::getModelTime($where, new self())->where($datawhere)->count(),
                'content' => '返利总笔数',
                'background_color' => 'layui-bg-blue',
                'sum' => self::where($datawhere)->count(),
                'class' => 'fa fa-bar-chart',
            ],
            [
                'name' => '返利金额（元）',
                'field' => '个',
                'count' => self::getModelTime($where, new self())->where($datawhere)->sum('number'),
                'content' => '返利总金额',
                'background_color' => 'layui-bg-cyan',
                'sum' => self::where($datawhere)->sum('number'),
                'class' => 'fa fa-line-chart',
            ],
        ];
    }

    //获取返佣用户信息列表
    public static function getFanList($where)
    {
        $list = self::alias('a')->join('user r', 'a.uid=r.uid')
            ->where('a.category', 'now_money')
            ->where('a.type', 'brokerage')
            ->where('a.pm', 1)
            ->order('a.number desc')
            ->join('store_order o', 'o.id=a.link_id')
            ->field('o.order_id,FROM_UNIXTIME(a.add_time,"%Y-%c-%d") as add_time,a.uid,o.uid as down_uid,r.nickname,r.avatar,r.spread_uid,r.level,a.number')
            ->page((int)$where['page'], (int)$where['limit'])
            ->select();
        if (count($list)) $list = $list->toArray();
        return $list;
    }

    //获取返佣用户总人数
    public static function getFanCount()
    {
        return self::alias('a')->join('user r', 'a.uid=r.uid')->join('store_order o', 'o.id=a.link_id')->where('a.category', 'now_money')->where('a.type', 'brokerage')->where('a.pm', 1)->count();
    }

    //获取用户充值数据
    public static function getEchartsRecharge($where, $limit = 15)
    {
        $datawhere = ['category' => 'now_money', 'pm' => 1];
        $list = self::getModelTime($where, self::where($datawhere)->where('type', 'in', ['recharge', 'system_add']))
            ->field('sum(number) as sum_money,FROM_UNIXTIME(add_time,"%Y-%c-%d") as un_time,count(id) as count')
            ->group('un_time')
            ->order('un_time asc')
            ->select();
        if (count($list)) $list = $list->toArray();
        $sum_count = self::getModelTime($where, self::where($datawhere)->where('type', 'in', 'recharge,system_add'))->count();
        $xdata = [];
        $seriesdata = [];
        $data = [];
        $zoom = '';
        foreach ($list as $value) {
            $xdata[] = $value['un_time'];
            $seriesdata[] = $value['sum_money'];
            $data[] = $value['count'];
        }
        if (count($xdata) > $limit) {
            $zoom = $xdata[$limit - 5];
        }
        return compact('xdata', 'seriesdata', 'data', 'zoom');
    }

    //获取佣金提现列表
    public static function getExtrctOneList($where, $uid)
    {
        $list = self::setOneWhere($where, $uid)
            ->field('number,link_id,mark,FROM_UNIXTIME(add_time,"%Y-%m-%d %H:%i:%s") as _add_time,status')
            ->select();
        count($list) && $list = $list->toArray();
        $count = self::setOneWhere($where, $uid)->count();
        foreach ($list as &$value) {
            $value['order_id'] = Db::name('store_order')->where('order_id', $value['link_id'])->value('order_id');
        }
        return ['data' => $list, 'count' => $count];
    }

    //设置单个用户查询
    public static function setOneWhere($where, $uid)
    {
        $model = self::where('uid', $uid)->where('category', 'now_money')->where('type', 'brokerage');
        $time['data'] = '';
        if (strlen(trim($where['start_time'])) && strlen(trim($where['end_time']))) {
            $time['data'] = $where['start_time'] . ' - ' . $where['end_time'];
            $model = self::getModelTime($time, $model);
        }
        if (strlen(trim($where['nickname']))) {
            $model = $model->where('link_id|mark', 'like', "%$where[nickname]%");
        }
        return $model;
    }

    //查询积分个人明细
    public static function getOneIntegralList($where)
    {
        return self::setWhereList(
            $where, '',
//            ['deduction','system_add','sign'],
            ['title', 'number', 'balance', 'mark', 'FROM_UNIXTIME(add_time,"%Y-%m-%d") as add_time'],
            'integral'
        );
    }

    //查询个人签到明细
    public static function getOneSignList($where)
    {
        return self::setWhereList(
            $where, 'sign',
            ['title', 'number', 'mark', 'FROM_UNIXTIME(add_time,"%Y-%m-%d") as add_time']
        );
    }

    //查询个人余额变动记录
    public static function getOneBalanceChangList($where)
    {
        $list = self::setWhereList(
            $where, '',
//            ['system_add','pay_product','extract','pay_product_refund','system_sub','brokerage','recharge','user_recharge_refund'],
            ['FROM_UNIXTIME(add_time,"%Y-%m-%d") as add_time', 'title', 'type', 'mark', 'number', 'balance', 'pm', 'status'],
            'now_money'
        );
        foreach ($list as &$item) {
            switch ($item['type']) {
                case 'system_add':
                    $item['_type'] = '系统添加';
                    break;
                case 'pay_product':
                    $item['_type'] = '商品购买';
                    break;
                case 'extract':
                    $item['_type'] = '提现';
                    break;
                case 'pay_product_refund':
                    $item['_type'] = '退款';
                    break;
                case 'system_sub':
                    $item['_type'] = '系统减少';
                    break;
                case 'brokerage':
                    $item['_type'] = '系统返佣';
                    break;
                case 'recharge':
                    $item['_type'] = '余额充值';
                    break;
                case 'user_recharge_refund':
                    $item['_type'] = '系统退款';
                    break;
            }
            $item['_pm'] = $item['pm'] == 1 ? '获得' : '支出';
        }
        return $list;
    }

    //设置where条件分页.返回数据
    public static function setWhereList($where, $type = '', $field = [], $category = 'integral')
    {
        $models = self::where('uid', $where['uid'])
            ->where('category', $category)
            ->page((int)$where['page'], (int)$where['limit'])
            ->order('id', 'desc')
            ->field($field);
        if (is_array($type)) {
            $models = $models->where('type', 'in', $type);
        } else {
            if (!empty($type)) $models = $models->where('type', $type);
        }
        return ($list = $models->select()) && count($list) ? $list->toArray() : [];
    }

    //获取积分统计头部信息
    public static function getScoreBadgeList($where)
    {
        return [
            [
                'name' => '历史总积分',
                'field' => '个',
                'count' => self::getModelTime($where, new self())->where('category', 'integral')->where('type', 'in', 'gain,system_sub,deduction,sign')->sum('number'),
                'background_color' => 'layui-bg-blue',
                'col' => 4,
            ],
            [
                'name' => '已使用积分',
                'field' => '个',
                'count' => self::getModelTime($where, new self())->where('category', 'integral')->where('type', 'deduction')->sum('number'),
                'background_color' => 'layui-bg-cyan',
                'col' => 4,
            ],
            [
                'name' => '未使用积分',
                'field' => '个',
                'count' => self::getModelTime($where, Db::name('user'))->sum('integral'),
                'background_color' => 'layui-bg-cyan',
                'col' => 4,
            ],
        ];
    }

    //获取积分统计曲线图和柱状图
    public static function getScoreCurve($where)
    {
        //发放积分趋势图
        $list = self::getModelTime($where, self::where('category', 'integral')
            ->field('FROM_UNIXTIME(add_time,"%Y-%m-%d") as _add_time,sum(number) as sum_number')
            ->group('_add_time')->order('_add_time asc'))->select()->toArray();
        $date = [];
        $zoom = '';
        $seriesdata = [];
        foreach ($list as $item) {
            $date[] = $item['_add_time'];
            $seriesdata[] = $item['sum_number'];
        }
        unset($item);
        if (count($date) > $where['limit']) {
            $zoom = $date[$where['limit'] - 5];
        }
        //使用积分趋势图
        $deductionlist = self::getModelTime($where, self::where('category', 'integral')->where('type', 'deduction')
            ->field('FROM_UNIXTIME(add_time,"%Y-%m-%d") as _add_time,sum(number) as sum_number')
            ->group('_add_time')->order('_add_time asc'))->select()->toArray();
        $deduction_date = [];
        $deduction_zoom = '';
        $deduction_seriesdata = [];
        foreach ($deductionlist as $item) {
            $deduction_date[] = $item['_add_time'];
            $deduction_seriesdata[] = $item['sum_number'];
        }
        if (count($deductionlist) > $where['limit']) {
            $deduction_zoom = $deductionlist[$where['limit'] - 5];
        }
        return compact('date', 'seriesdata', 'zoom', 'deduction_date', 'deduction_zoom', 'deduction_seriesdata');
    }

    /**
     * 用户获得总佣金
     * @return float
     */
    public static function getBrokerageCount()
    {
        return self::where('type', 'brokerage')->where('category', 'now_money')->where('status', 1)->where('pm', 1)->sum('number');
    }

    /**
     * 获取所有的订单情况
     * @param array $where
     */
    public static function getAllBill(array $where)
    {
        $model = self::setWhere($where);
        $count = $model->where("b.wxapp_id", self::$wxapp_id)->count();
        $data =  $model->where("b.wxapp_id", self::$wxapp_id)
            ->field("b.*, u.nickname, u.phone, wx.headimgurl")
            ->order("b.add_time DESC, b.id DESC")
            ->page((int)$where['page'], (int)$where['limit'])
            ->select()->each(function ($item, $key){
                $item["add_time"] = date("Y-m-d H:i:s");
                $item["last_time"] = date("Y-m-d H:i:s");
                if ($item["type"] == "1") {
                    $item["type"] = "智能洗车";
                } elseif ($item["type"] == "2") {
                    $item["type"] = "积分充值";
                } else {
                    $item["type"] = "优惠券购买";
                }
                if ($item["sex"] == 1) {
                    $item["sex"] = "男";
                } elseif ($item["sex"] == 2) {
                    $item["sex"] = "女";
                } else {
                    $item["sex"] = "未知";
                }
            });
        return compact("count", "data");
    }

    /**
     * 设置where条件
     * @param array $where
     */
    private static function setWhere(array $where)
    {
        $model = new self();
        $model = $model->alias("b")
            ->join("user u", "u.uid= b.uid")
            ->join("wechat_user wx", "wx.uid=b.uid");
        if (isset($where["user_id"]) && !empty($where["user_id"])) $model = $model->where("b.uid", "=", $where["user_id"]);
        if (isset($where["nickname"]) && !empty($where["user_id"])) $model = $model->where("u.nickname|u.phone", "like", "%{$where['user_name']}%");
        if (isset($where["sex"]) && !empty($where["sex"])) $model = $model->where("wx.sex", "=", $where['sex']);
        if ($where['user_time_type'] == 'visitno' && $where['recent_time'] != '') {
            list($startTime, $endTime) = explode(' - ', $where['recent_time']);
            $endTime = strtotime($endTime) + 24 * 3600;
            $model = $model->where("c.recent_time < " . strtotime($startTime) . " OR c.recent_time > " . $endTime);
        }
        return $model;
    }
}